entry 基本配置

config.entry : {String|Object} Webpack 构建入口文件配置

这里的entry 对 Webpack 的 entry 进行了增强, 除了支持 webpack 原生 Object(key:value) 方式配置, 还对entry进行了增强。

Webpack entry 原生配置

// ${app_root}/webpack.config.js
module.exports = {
  ......
  entry:{
    home: path.join(__dirname, 'src/page/home/home.js')
  }
}

Webpack entry 自动遍历配置

// ${app_root}/webpack.config.js
module.exports = {
  ......
  entry:{
    include:['src/page']
    exclude:[]
  }
}
  • config.entry.include : {String/Object/Array/Regex} 必选, 文件根目录可以不写

  • config.entry.exclude: {String/Array/Regex} 可选, 排除不需要构建的文件或目录, 支持正则表达式.

  • config.entry.loader: {Object}, 可选, 为 entry 配置模板, 当配置后, 可以根据 .vue.jsx文件自动创建 entry 文件, key为 config.type 枚举值. 示例

  • config.entry.extMath: {String}:, 可选, entry目录查找时匹配文件后缀, 默认 .js, 当配置了 config.entry.loaderconfig.framework 参数,自动映射后缀.

entry 自定义初始化入口代码模板

在基于 Webpack 构建时, 我们通常都是用 js 作为 entry 入口问题, 这样需要自己写页面初始化的代码,这样导致入口代码重复繁琐, 需要简化.

在进行页面构建时, 我们希望有统一的入口模板功能, 这样进行页面构建和js构建时, 就不需要写同样的入口代码, easywebpack 提供 entry.loader 模板功能.

在 Vue/React 项目构建时, 通过 loader 模板配置, 我们可以直接基于 .vue或.jsx 作为入口文件.

// ${app_root}/webpack.config.js
module.exports = {
 entry: {
   include: ['app/web/page', { 'app/app': 'app/web/page/app/app.js?loader=false' }],
   exclude: ['app/web/page/[a-z]+/component', 'app/web/page/app'],
   loader: { // 如果没有配置loader模板,默认使用 .js 文件作为构建入口
      client: 'app/web/framework/vue/entry/client-loader.js',
      server: 'app/web/framework/vue/entry/server-loader.js',
   }    
}

配置说明:

  • app/web/page 目录中所有 .vue 文件当作 Webpack 构建入口. 客户端构建采用 app/web/framework/vue/entryclient-loader.js , 服务端渲染构建使用 server-loader.js 模板文件。

  • 上面 { 'app/app': 'app/web/page/app/app.js?loader=false' } 这个 loader=false 的含义表示 app/web/page 目录下的 app/app.js 不使用 entry.loader 模板。因为这个app/app.js是一个SPA服务端渲染Example,实现逻辑与其他普通的页面不一样,不能用 entry.loader 模板, 这个功能在自定义entry文件构建规范时使用。

entry 使用框架内置默认初始化代码模板 (easywebpack 4.8.0 新增支持)

config.entry : {String} 必选, 使用 node-glob 遍历文件, 配置举例:

  • 自动遍历 src/page 目录的所有** js 文件 **作为 entry 入口,排除 component|components|view|views 目录下的文件. 这个需要自己实现 Vue/React 项目初始化入口代码逻辑,可以 vue-entry-loaderreact-entry-template-loader 的代码拷贝到项目里面使用。
// webpack.config.js
module.exports = {
  entry: 'src/page/**!(component|components|view|views)/*.js'
}
  • 自动遍历 app/web/page 目录的所有** .vue 文件 **作为 entry 入口,排除 component|components|view|views 目录下的文件。 如果 webpack entry 是 .vue 文件, 自动使用 vue-entry-loader 作为模板入口。
// webpack.config.js
module.exports = {
  entry: 'app/web/page/**!(component|components|view|views)/*.vue'
}
  • 自动遍历 app/web/page 目录的所有 jsx 文件作为 entry 入口,排除 component|components|view|views 目录下的文件。如果 webpack entry 是 .jsx 文件, 自动使用 react-entry-template-loader 作为模板入口。
// webpack.config.js
module.exports = {
  entry: 'app/web/page/**!(component|components|view|views)/*.jsx'
}

Author: sky
Reprint policy: All articles in this blog are used except for special statements CC BY 4.0 reprint polocy. If reproduced, please indicate source sky !
 Previous
JS 文件打包 JS 文件打包
我们经常会遇到单独对 JS 打包的场景,比如 es6 写的 npm 包需要构建成 es5 模式.
2019-10-20 sky
Next 
Css Style Css Style
开启 Sass (默认禁用) webpack.config.js // ${app_root}/webpack.config.js module.exports = { module:{ rules:[ {
2019-10-20 sky